package Leetcode第一期;

/**
 * @author : K k
 * @date : 13:58 2020/9/15
 * 输入一棵二叉树的根节点，判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1，那么它就是一棵平衡二叉树。
 *
 *  
 *
 * 示例 1:
 *
 * 给定二叉树 [3,9,20,null,null,15,7]
 *
 *     3
 *    / \
 *   9  20
 *     /  \
 *    15   7
 * 返回 true 。
 *
 * 示例 2:
 *
 * 给定二叉树 [1,2,2,3,3,null,null,4,4]
 *
 *        1
 *       / \
 *      2   2
 *     / \
 *    3   3
 *   / \
 *  4   4
 * 返回 false 。
 */
public class 平衡二叉树_55_II {

    public boolean isBalanced(TreeNode root) {
        if (root == null) {return true;}
        return (Math.abs(depth(root.left)-depth(root.right))<=1 )&& isBalanced(root.left) && isBalanced(root.right);
    }

    //计算平衡数
    public int depth(TreeNode root){
        return root==null? 0 :Math.max(depth(root.left),depth(root.right))+1;
    }

}
